草庐IT

SQL - 空白默认命名空间

全部标签

ruby-on-rails - Rails 和日期,它们默认存储在 UTC 中吗?

我在Rails中处理日期和时区的最佳方式是什么?场景:我有客户在世界各地的网站上购买产品,当他们登录时,他们将能够选择他们来自哪个时区。所以我认为我应该以UTC将所有内容存储在数据库中,然后在前端我应该将日期转换为用户设置的时区首选项。他们在Ruby和Rails以及日期时间等方面有什么问题吗?我是Rails的新手,所以我正在寻找有关如何正确处理此问题的指导。 最佳答案 幸运的是,Rails几乎可以为您处理很多事情。正如其他人指出的那样,AR以UTC格式存储日期。如果您的用户表有一个time_zone字段,您可以这样做:#applic

sql - 按年、月分组,然后在 ActiveRecord 3 中计数

我正在尝试统计一年和一个月内创建的所有用户,但以下内容似乎没有按预期工作。User.group("YEAR(created_AT),MONTH(created_at)").count("DISTINCT(id),YEAR(created_at),MONTH(created_at)")我在找类似的东西{2011=>{1=>222,2=>333,4=>444,5=>667...}}但是我得到了{1=>222,2=>333,4=>444,5=>667...}我是不是遗漏了什么,或者ActiveRecord不能在一次查询中给我这个结果? 最佳答案

ruby - 模拟默认对象#inspect 输出?

o=Object.newo.instance_eval{@str="foo"}po#=>#这很好。使用对象作为参数调用p会打印对象inspect方法的输出。但是,不幸的是,如果对象重写了to_s方法,那么它将输出该方法的输出:class"foo"po#=>foo所以要解决这个问题,我们必须在我们的对象上定义一个inspect方法:class"blah"如何使对象的inspect方法输出默认的Ruby方式,如第一个代码示例的第3行所示?我最接近的是下面的,但我不确定它是否完全正确class"endend 最佳答案 为了使数字与原来的实

ruby-on-rails - 使用迁移更改表列的默认值

我尝试将默认列值从false更改为true。但是当我运行rakedb:migrateVERSION=904984092840298时,我得到了以下错误。StandardError:Anerrorhasoccurred,thisandalllatermigrationscanceled:PG::InvalidTextRepresentation:ERROR:invalidinputsyntaxfortypeboolean:"---:from:false:to:true":ALTERTABLE"plussites"ALTERCOLUMN"hide_season_selector"SETDE

ruby-on-rails - 类 CommentsController 的父类(super class)不匹配(TypeError),重命名的最佳方法?

我今晚在部署时遇到了一些问题,我正在努力尽快解决这个问题我不知道为什么会这样。在本地一切正常,但在heroku上却不行。我在研究后尝试了各种不同的修复方法,但我可能不得不求助于完全重命名此类CommentsController(希望能奏效)。最好的方法是什么?我是Rails的新手,所以我需要一些帮助来正确地进行这些更改。这是CommentsController的样子,仅供引用:classCommentsController评论与每个帖子相关联(用户可以对帖子发表评论)。如果需要,我也会发布其他代码。这是来自heroku日志的错误2013-04-09T05:55:19.454545+00

ruby-on-rails - 如何获取给定内容类型的默认扩展名?

给定变量content_type="application/pdf"也可以包含任何其他mime类型。如何获取内容类型的默认扩展名?我目前有两个解决方案,看起来很“复杂”。破解字符串content_type.split("/")[1]使用MIME::类型require'mime/types'MIME::Types[content_type].first.extensions.first有没有更好的解决方案? 最佳答案 您只需使用ruby​​的Hash.invert方法即可。Thisanswer展示了如何做:Rack::Mimehast

ruby-on-rails - ruby 命名空间

我是ruby​​的新手,来自php背景,但有些东西不适合我。所以,假设我有一个RubyonRails应用程序,并且我正在像这样对我的API进行版本控制:app|_controllers|_api||_v1|||_application_controller.rb|||_user_controller.rb||_application_controller.rb|_application_controller.rb与类结构同#VersionedAPIV1appcontrollermoduleApimoduleV1classApplicationControllerendendend#Ve

sql - 如何在 rails 中添加条件 where 子句

我是一名Rails新手,我正在尝试使用Rails对表执行搜索,而我只是使用我的sql知识来执行此操作。但这看起来不像是rails或ruby​​...有没有更好的方法来做我在下面做的事情?(基本上,如果日期参数已填充,则只将日期参数传递给sql)defsearch(begin_date=nil,end_date=nil)subject="andcreated_at"if!(begin_date.nil?||end_date.nil?)where_part=subject+"BETWEEN:begin_dateAND:end_date"elseif(begin_date.nil?&&end

sql - PostgreSQL 条件 where 子句

在我的RubyonRails应用程序中,我使用的是blazer(https://github.com/ankane/blazer)并且我有以下sql查询:SELECT*FROMsurvey_resultssrLEFTJOINclientscONc.id=sr.client_idWHEREsr.client_id={client_id}这个查询非常有效。但是我需要添加条件逻辑来检查client_id变量是否存在。如果是,那么我将按此变量进行过滤,如果不是,则我不会启动此where子句。我如何在PostgreSQL中执行此操作? 最佳答案

ruby - 如何重命名 S3 存储桶中的文件夹?

听起来很简单,但这似乎是一项异常复杂的任务。 最佳答案 如果您使用的是aws-s3gem,则以下代码会将存储桶BUCKET_NAME中的文件夹OLD_FOLDER_NAME重命名为NEW_FOLDER_NAME:bsize=OLD_FOLDER_NAME.sizebucket=AWS::S3::Bucket.find(BUCKET_NAME)bucket.objects({:prefix=>OLD_FOLDER_NAME}).eachdo|o|AWS::S3::S3Object.rename(o.key,NEW_FOLDER_NAM